package LeetCodeTask.Sort;

/**
 * 给你一个整数数组 salary ，数组里每个数都是 唯一 的，
 * 其中 salary[i] 是第 i 个员工的工资。
 * 请你返回去掉最低工资和最高工资以后，剩下员工工资的平均值。
 *
 * 示例 1：
 * 输入：salary = [4000,3000,1000,2000]
 * 输出：2500.00000
 * 解释：最低工资和最高工资分别是 1000 和 4000 。
 * 去掉最低工资和最高工资以后的平均工资是 (2000+3000)/2= 2500

 */
public class AverageSalary {

    public double average(int[] salary) {

        double sum = 0;
        double maxValue = Integer.MIN_VALUE,minValue = Integer.MAX_VALUE;
        for (int val:salary) {
            sum += val;
            maxValue = Math.max(maxValue,val);
            minValue = Math.min(minValue,val);
        }

        return (sum-maxValue-minValue) / (salary.length-2);
    }
}
